## CS1026 II Assignment 9

A synchronous finite state machine has an input  $x_i$  and an output  $y_i$  out. When  $x_i$  in changes from 0 to 1, the output  $y_i$  out is to assert for three cycles, regardless of the value of  $x_i$  and then de-assert for two cycles before the machine will respond to another assertion of  $x_i$  in.

- (a) Draw the state diagram of the machine.
- (b) Write Verilog model of the machine. module StateDiagram (output y\_out, input x\_in, clk, reset\_b);

Test data will change on the falling edge of the clock and your machine should change state on the rising edge.

Your design should enter state 0 on the negative edge of the reset signal.

CS1026 II 1